package cn.tanghom.baiding.service.system.dao;

import cn.tanghom.baiding.api.system.model.Role;
import cn.tanghom.baiding.core.dao.BaseDao;
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Repository;

import java.util.List;

/**
 * RoleMapper 角色管理映射
 *
 * @author tanghom<tanghom@qq.com> 2016/4/24
 */
@Repository
public interface RoleDao extends BaseDao<Role> {

    /**
     * 根据角色Key或名称查找角色
     *
     * @param key
     * @param name
     * @return
     */
    Role selectByNameOrKey(@Param(value = "name") String name, @Param(value = "key") String key);

    /**
     * 查询所有
     *
     * @return
     */
    List<Role> selectListByParams(@Param(value = "name") String name, @Param(value = "key") String key);

    /**
     * 查询分页
     *
     * @param name  角色名称
     * @param key   角色key
     * @param first 数据第几条查询
     * @param size  查询数量大小
     * @return
     */
    List<Role> selectPageByParams(@Param(value = "name") String name, @Param(value = "key") String key, @Param(value = "first") Long first, @Param(value = "size") Integer size);

    /**
     * 分页返回条数
     *
     * @param name 角色名称
     * @param key  角色key
     * @return
     */
    Long selectCountByParams(@Param(value = "name") String name, @Param(value = "key") String key);

    /**
     * 分页返回条数
     *
     * @param userId 用户Id
     * @return
     */
    List<Role> selectUserRoles(@Param(value = "userId") Long userId);

}
